Batch 2 - Class 263 - Math in Genetics III - DNA Computing

(zoom)

Preclass Exercise

AttendanceAdvay, Raghav, Ayush, Aneesh, Shikhar, Rohan, Mihir, Vivaan, Aarkin, SiddhantJ, Kushagra, Vansh, Harshiet, Angad, Rehaan, Kabir, Siddharth

Class Notes:
Recap

Homework problem
Consider the maze below
We are trying to find a path through the maze. Each path may be encoded as a sequence of "turns" - what does the path do when it encounters an obstacle (in absence of an obstacle, the path continues in a straight line). The actions might be L,R,B (left, right, back). Let us also say that the path has maximum length of 12 - i.e. if the path doesn't lead to "*" after 12 "turns" and encounters an obstacle, that path is over.

Think about how you would design a genetic algorithm to solve this. What would your coding look like? How will you introduce variation? How would you ensure that "good" features will persist? How will you define "fitness"?

If you know how to code, try to code this! Else try to run your "algorithm" on a random starting string, and see if the fitness scores improve from one generation to another.

Some possible lines of thinking

DNA Computers
Note that genetic algorithms do not really use DNA or genes - its just the principles of natural selection applied to computing and algorithms

One can actually use the DNA replication machinery present in living organism as a computer itself. 

Why?

Basics

Lets see an example



Homework

References:   
    Mathematical Puzzles, Geoffrey Mott-Smith
    https://en.wikipedia.org/wiki/DNA_computing
    https://slideplayer.com/slide/4713908/